MULTICS TECHNICAL BULLETIN 



MTB-120 



TO: Distribution 

FROM: J. W. Gintell 

DATE: September 30, 197^ 

SUBJECT: Nev probe command 



Attached is the documentation on the nev probe command. Any 
comments may be submitted to Jeff Broughton or John Gintell. 



Multics Project internal working documentation. Not to be reproduced 
or distributed outside the Multics Project. 



MULTICS PROGRAMMERS' MANUAL 



Command 
07/16/74 



Hanue* probe, pb 



The probe command is a symbolic debugging aid that allows 
the user to interactively examine the state of his orooram. 
Commands are provided to display and alter the value of 
variables, to interrupt a running Droaram at a oarticular 
statement by use of breakpoints, to list the source prooram, to 
examine the stack of block invocations, and to invoke external 
subroutines and functions. 

In order to debug a program with Drobe, the program must 
have a standard symbol table that contains information about 
variables defined in the program and a statement map givina th<=- 
correspondence between source statements and object code. A 
symbol table and statement map is produced by the PL/I and 
Fortran compilers if the "-table" ODtion is specified. (A 
program may also be compiled with the "-brief_table» option 
W !?i^ W i U P roduce only the statement map and disable the 
ability to reference variables.) 

To store certain information about orograms being debuoned, 
probe uses a segment in the user's home directory called 
Username. probe where Username is the user's oersonid. This 
segment is created automatically when needed, 

Ia££QductlQg« 

The primary use of probe is to examine a proaram whose 
execution has been suspended. This can occur in one of several 
ways. 

First, execution may be interrupted as a result of an error 
occurring in the program such as zerodivide or overflow. After 
an error message is printed on the user's console, and a new 
command level entered, probe may be called and commands issued 
to it to identify the cause of the error. 

Second, the user can, as always, stop a run-away orooram by 
"quitting". 

Third, the user may designate, by use of probe's break 
commands, statements on which the program is to stop and directly 
enter probe. A list of commands associated with the break 
would then be executed automatically. These commands could print 
a variable, tell what line was just executed, or cause orobe to 
read additional commands from the console. In this way, the user 
can follow the progress of his program before an error occurs. 

© 1974, Honeywell Information Systems Inc. 
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In all of the cases above, an active program has been 
suspended. This means that variables of all storage classes, in 
particular automatic, exist and may be displayed. Probe may 
also be used to examine a non-active program — one that has 
never been run or that has completed. Used in this manner, probe 
can be used to look at static variables, and the program source, 
though the most common use is to set breaks before actually 
running the program. 

Probe maintains three "pointers" that can affect the 
execution of many commands. They are* the source p ointer which 
marks a particular source program statement as the "current 
statement" and the program as the "current program"; the symbol 
pointer which indicates the "current block" and generation of 
storage (i.e. stack frame) in which to evaluate symbolic 
references to variables; and the control pointer which 
designates the statement at which control was suspended in the 
procedure of interest. 

Usage.* 

probe -<procedure>- 

where <procedure> is an optional argument giving the name of an 
entry which the user is interested in. If the procedure is 
active, the control and source pointers will be set to the last 
statement executed, and the symbol pointer will be set to the 
most recent invocation of the procedure. If it is not active, 
then the control and source pointers will be set to point to the 
entrv statement, and the symbol pointer will designate the 
outermost block of the procedure. 

If a <procedure> is not specified, probe will, check if an 
error or quit has occurred and, by default, use the procedure 
that was executing. The pointers will be set as if the user had 
specified it explicitly. If no error has occurred, then probe 
will print a message and return. 

When probe Is entered as the result of executing a procedure 
with a breakpoint set in it, the control and source pointers are 
set to the statement on which the break was set, and the symbol 
pointer to the block that contains that statement. 

In general, after an error, quit, or break, things will be 
set up by default much as one would expect. The user should, 
however, explicitly name a <procedure> when he is interested in 
working with a non-active one. 



MULTICS PROGRAMMERS' MANUAL 




Pane 3 



Once probe has been entered, the user mav Issue commands to 
it In order to examine his program. 



Comma n d Svntax t 



The command Ian qua qe 
commands, command lists, 
simple command is a 
list of commands 
conditional command 
parentheses) prefixed 
the request is to 
section. 



recognizes three constructs* simple 

and conditional commands. Loosely, a 

request, and a command list is a 

by semi-colons (or newllnes). A 

command or list (surrounded by 

a conditional predicate controlling when 

performed. Examples follow in the next 



basic probe 

separated 
is a simple 

by 

be 



In the discussion of commands that follows, 
symbols will be used for certain constructs (e.g. 
Their meaning should be apparent from context and 
given. A complete discussion will be found 
write up. 



meta-language 
<expression>) . 
from examples 
later in this 
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Basic Commands 

print* a 

print <<expression>! <cross section>> 

Output on the console the value of <expression>. The print 
request allows the user to display the value of variables, 
builtin functions such as addr and octal, and the value returned 
by an external function. 

print var 

print p -> a.b( j) .c 
print addr (i) 
print octal (ptr) 
print function (2) 

Array cross-sections may be displayed by specifying the upper and 
lower bound of the cross-section as follows! 

print array (1 *5, 1 ) 

which would print array<1,1), array(2,1), ..., array(5,l). More 
than one dimension may be iterated; for instance a(1»2,1*2) would 
print, in order, a( 1 , 1 ), a<1,2), a(2,1), a(2,2). 

l£i, 1 

let {<variable> !<cross section>> = <expression> 

Set the <variable> specified to the value of the <expression>. 
If the types are not the same, conversion will be performed 
according to the rules of PL/I. Array cross-sections may be 
used with the same syntax as in print. Note that one may not 
assign one array cross-section to another. 

let var =2 

let array (2,3) = i + 1 

let p -> a.b('U2).c = 10b 

let ptr = null 

Warning* because of compiler optimization, the change may not 
have immediate effect in the program. 
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.continue., £ 

continue 

Cause probe to return to its caller. If entered from command 

level, probe will return to command level. After a break, the 

user's program will, in effect, be restarted. To abort a 
debugging session, the quit button must be used. 

call, £1 

call <procedure>([<expression>[,<expression>] ...]) 

Call the subroutine with the arguments given. If the orocedure 
has descriptors giving the type of the arguments expected, the 
ones given will be converted, to the expected type; otherwise, 
they will be passed as they are. The print request may be used 
to invoke a function, with the same sort of arctument conversion 
taking place. Notei if the procedure has no arnuments, a null 
argument list, «'()«', must be aiven. 

call sub («abc», p -> P 2 -> bv, £5o, addr(p) 
call sub_noargs () 
print function ("010»b) 

OQj&, aa Jt£» go., a 

goto <label> 

Cause an exit from probe and a non-local ooto to the statement 
specified. 

goto label_var - transfer to value of label 

variable 
goto action (3) - transfer to label constant 
^to 29 - transfer to statement on line 29 

of current prooram 
goto $110 - transfer to line labeled HO in 

the fortran program 

Warning: because of compiler oDtimization, unpredictable results 
may occur. 



orobe 
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Source, caomaacis 



JLLsi, is. 

list [Q] 



Direct one 
(i.e. the 
statements 



or n statements beginning with the current statement 
source pointer) to be printed. Note: only executable 

for which code has been generated can be listed? 
however, if several statements are requested, intervening text 
such as comments and non-executable statements will be included 
in the output. 

posiiioxi, pa 

position <label> 
position <+!-}q 

Set the source pointer to the statement indicated or to plus or 
minus o, executable statements relative to the current statement. 



oosition label 
position action (3) 
position 2-14 

position +2 

oosition -5 



- set the source ptr to label! ... 

- to action (3) » ... 

- to statement on line 14 of file 2 
of the program 

- move forward 2 statements in the 
source 

- move back 5 statements 



find* t 



find »<string>" 

Search for an executable statement containing the characters in 
<string> and if found, set the source pointer to that statement. 
The search begins after the current statement and continues 
around the program as in the editors edm and qedx. Note: because 
of reordering of statements by the compiler, which, amonq other 
thinqs, moves suborograms to the end, the search may not 
necessarilv find things in the same order as one would expect 
from a source listing of the orooram. 



find "write (6,10)" 

find "str = ""a" 
find »q+2"; list 



- locate the statement in 
program 

- locate str = "a 

- locate and print the statement 



the 
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Symbol 



s£a£k, sk 



stack [[ijul Call] 

Trace the stack backward from the ith frame for q frames. If no 
limits are given, the entire stack will be traced. The trace 
consists of a list of active procedures and block invocations 
(including quick blocks) beginning with the most recent. In 
addition to the name of the block, a frame or level number is 
given, as is the name of any conditions raised in the frame. 



stack 
stack 3 
stack 3, 2 



- trace the whole stack 

- trace the first three frames 

- trace th 3rd and 4th frames 



Normally, system or subsystem support procedures will not be 
included in the stack trace. If desired, thev may be included by 
specifying "all". 

stack all 
stack 3,5 all 



US&* U 



use C<block>3 



Selects a new block or procedure to be examined. If no <block> 
is given, then the block originally used when probe was entered 
will be assumed. The symbol pointer is set to the <block> 
specified so that variables in that block can be referenced. In 
addition, the source oointer is set to the 
executed in the block? in this way, the point at 
exited may be found with the help of the 
Acceptable <block>s include: 



last 
which 
list 



statement 

the block 

command. 



<procedure> 
<label> 
level i 

- Q 



Here <procedure> is the name of a procedure whose frame is 
desired; its usaae is essentially the same as if used on the 
command line. A <label> denotes the block containing the 
statement identified by the label or line number — for instance, 
the label on a begin statement denotes that begin block. If the 
<label>s block is not active, the source pointer will be set to 
the statement specified, "level i» will use the ith block frame 
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from a stack trace, "-a" will use the nth previous instance of 
the current block allowing one to move back to a previous 
recursion level. (If more frames are requested than actually 
exist, the last one found will be used.) 

use sub - use block procedure sub occupies 

use label - use block containina label x ... 

use level 2 - use second frame in stack trace 

use -1 - use previous instance of current 

block 
use -999 - use first (oldest) instance 

symbol 

symbol <identifier> 

Display the attributes of the variable specified and the name of 
the block in which its declaration is found. If the variable has 
variable size or dimensions, an attempt will be made to evaluate 
the size or extent expression; if the value is not available, 
then "*" will be used instead. 

where, jab 

where [ source 5 symbol [control ] 

Display the current value of one or all of the pointers. Source 
and control will give the statement number of the correspondinq 
statement. Symbol will give the name of the block currently 
beina used; If the block Is active, its level number will also 
aopear. 

where - give value of all three pointers 

where source - give the value of the source 

pointer 
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Break Commands 



los&db* i 



insert [<label>3» < <command> ! < <command list>)} 



Set a breakpoint before the statement 
cause the command(s) given to be associat 
no <label> is given, the current statemen 
the running program arrives at the 
entered bfilarjS the statement is executed, 
be processed automatically. When fin 
probe will return, and the program will r 
at which the break was set. In effec 
probe commands into his program. 



specified by <l.abel> and 
ed with the' break. If 
t will be assumed.' When 
statement, probe will be 
and the commands will 
ished with the commands, 
esume at the statement 
t, the user may "insert" 



inserts (print var? print var2) 

- set a break before the current 
statement 
insert quick* print x - set a break before the statement 

labeled quick 

Note that the command list may extend across line boundaries if 
necessary. 

append, a 

append [<label>]i {<command> J (<command list>)> 

is the same as insert except that the break is set after the 
statement designated. This means that the command list will be 
interpreted after the statement has been executed. If the 
statement branches to another location in the program, probe will 
oai be entered. The difference between appendina at one 
statement and inserting at the next is that a transfer to the 
next statement would cause a break for the insert case but would 
not for the append one. 

Stop, SB. 

stop 

Causes probe to stop processing Its current input and read 
commands from the console. A new invocation of probe is created 
with new pointers set to the values at the time "stop" was 
executed. It is of primary use as part of a break command list 
as it enables the the user to enter commands while a program is 
suspended by a break. In effect, he may halt a running program. 
A subsequent continue command would cause probe to resume what it 



probe 
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was doing before stopping — for instance, finish a break command 
list and return to the program. The command* 

insert 29* stop 

would cause the program to halt at statement 29 and allow the 
user to enter probe commands. Continue would restart the program. 
Similarly* 

append* (print ai stop? print b) 

would cause the value of a to be printed before the program 

halted? later., after the user entered a "continue" command, the 

value of b would be printed, and the execution of the program 
resumed. 

reset 

reset {at iafter Ibefore) <label> 

reset <procedure> 

reset * 

Delete breaks set by the insert or append commands. Just "reset" 
deletes the last break that occurredl the <label> form deletes 
breaks set before and/or after a statement? <procedure> and "*" 
may be used to reset all the breaks in a segment, and all breaks 
in all segments, respectively. 



reset 
reset at 34 

reset after 34 

reset sub 
reset * 



- delete the current break 

- delete breaks inserted 
appended at 34 

- delete the break appended 
34 

- delete all breaks in sub 

- delete all breaks known 



and 
after 



s , tatus t s,t 



status 

status {at! after Jbefore) <label> 

status <procedure> 

status * 



Give information about what breaks have been set. 
the requests is similar to "reset"* 



The scope of 



status 

status before label 



- list the current break 

- list the break inserted at label* 
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- tell what breaks have been set In 
sub 

- tell what procedures have breaks 
set in them 



pause 

Equivalent to "stop* reset* in a break command list, it causes 
the procedure to execute a break only once — , stopping, then 
reseting the break. 

SXa&t s 
step 

Set break consisting of "pause" after the statement following the 
control pointer and "continue". It enables the user to step 
through his program one statement at a time. Note* that if a 
statement transfers elsewhere, the break will not happen until 
sometime later, if ever. 



Btscftl lanftnna Commands 

brief tonioff] 

Turn brief message mode on or off. In brief mode, most messages 
generated by probe will be much shorter and others will be 
surpressed altogether. The default is off . 

£X££li££, &X££, &X 

execute "<string>" 

Pass <string> to the command processor to be executed as a normal 
Multics command. 
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if 

if <conditlonal>« <<simple command>l (<command list>)> 

The conwnand(s) will be executed if the <conditional> evaluates to 
true. The <conditional> may be of the form 

<expressionXop><expression> with <*, <, =, A =, >, >= allowed as 
<op>s. 

if a < bt let p = addr (a) 

This predicate is of most use in a break command list as it can 
be used to cause a conditional stop* 

insert! if z *■ *10"b* stop 

would cause the program to stop only when z **= *IO"b. 

wJbils, ttl 

while <conditional>* <<simple command>! (<command list>)} 

Allows iteration by executina the command(s) as lonq as the 
<conditional> is true. 

while p *= nulU (print p -> r.val? let p = p -> r.next) 
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Pypressf ons t 



Allowable <expression>s include simple scalar variables, 
constants, and probe builtin functions. The sum 3 and difference 
of computational values can also be used. 

Variables may be simple identifiers, subscripted references, 
structure qualified references, and locator qualified references. 
Subscripts are also expressions. Locators must be offsets or 
pointer variables or constants. 

running. total 
salaries (p -> i - 2) 
a.b(2).c(3) or a.b.c(2,3) etc. 
x.y -> var 

Arithmetic, string, bit, and pointer constants are 
supported. Arithmetic constants may be either decimal or binary, 
fixed or float, real or complex. Also, octal numbers are 
permitted as abbreviations for binary integers (e.g. 12o =10). 

-123 45.37 2.1-0.31 

10b 4.73e10 123456700 

Character and bit strings without repetition factors are allowed. 
Character strings may include new line characters. Octal strings 
may be used in the place of bit strings (e.g. "123»o = 
".00101001 1»b). 

"abc" "I010"b 

"quote»"instring" "01234567"o 

Pointer constants are of the formt seg#iword#(bit#) . The sea# 
and word# must be in octal. The bit# is optional and must be in 
decimal. They may be used as locators. 

21455764 232! 741 3(9) 

Three builtin functions are provided by probe* addr, null, 
and octal. The addr function takes one argument and returns a 
pointer to that argument. Null, taking no arguments, returns a 
null pointer. They are the same as in PL/I. The function octal 
acts very much like PL/I's unspec builtin in that it treats its 
argument as a bit string of the same length as the raw data 
value, and may be used in a similar manner as a psuedo-variable. 
However, when used in the print command the value is displayed in 
octal. (Data items not occupying a multiple of three bits will 
be padded on the righ t-) 
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> nces : 



A <label> identifies a source program statement and may be a 
label ' variable or constant, a line number as it apoears on a 
source listing (i.e. C£lIs-3iiQ£) , or a special 'statement 
designator* $c representing the "current statement", $b 
representing the statement on which the last break occurred, and 



Snumber. for fortran labels. 
is also allowed. 



An optional offset of the form 



label 
label_var 

17 
3-14,2 

$b 



$c,1 
$100 

Procedure Ref g r e n f,ftg t 



statement 

statement 

to 

statement 

statement 

statement 

occurred 

statement 



at label* ... 
that label_var 



is set 



on line 17 of program 
2 on line 14 of file 3 
at which last break 

after current statement 



- fortran statement labeled 100 



A <procedure> is considered to be a reference to an entry 
variable or constant. External names may be used. 



Ev a l u a tion pf 



L e Ref f 



When a variable is referenced in a command, orobe will 
attempt to evaluate it by first checkina for an apolicable 
declaration in the current block as indicated by the symbol 
pointer, and if necessary in its parents. If not found, the list 
of builtin functions will be searched. Finally, when the context 
allows a <procedure>, a search will be made followina the user's 
search rules. 



The block in which to look for a variable may be altered by 
the use command which sets the symbol pointer. For example, if 
"print var" displays the value of var in the current block, then 
"use -1; print var" displays the value of var at the previous 
level of recursion. A shorthand is available for referencino 
variables in other blocks — an optional block specification* 

<variable> i<block>l 

where block is the same as in the use command. The use of 
<block>s in this manner does not alter the symbol pointer. 
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vart-13 

abc[other_block] 

xyzC39] 

n^mC level 43 

q(2)Csub] 



- looks for previous value of var 

- looks In "other_block" for abc 

- looks in block containing line 39 

- looks in block at level 4 

- looks in procedure sub 



A block specification may be used on an identifier anywhere 
variable could be used. However, a block specification 
label or entry constant is ignored unless 1 ) the relative 
format is used, and 2) the label or entry is itself used 
block specif cation. In such a case, it is taken to mean the 
previous instance of the block designated by the label 
that is, "varCsub[-2]3" references var in the second 
invocation (third on the stack) of sub. 



the 

on a 

<-n) 

in a 

nth 

or entry? 

previous 



probe 
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Sample Debugging Session* 

The followino is a sample attempt at debuoging a program. 

It is not claimed that the program does anythina useful, or that 
this is the best way to debug the program. The purpose is merely 

to give an example of how certain probe commands can be aoplied. 

A listing of the source of the program, test, is aiven on the 

next page? the sample outout follows with »>» used to denote 
lines typed by the user. 

In order to use probe to debug a program, the proqram must 
be compiled with the "-table" option. Generally, the user should 
generate a symbol table for any proqram that he does not have 
good reason to believe will work. 

On line 5, the user calls his proqram? noticing that it 
seems to be loopinq, he stops it by hitting the quit button. 
After the user invokes probe, it responds by telling that the 
internal function "fun" was executing line 38 when interrupted. 
Since the source pointer was automatically set to that line, a 
request to print the current statement with "list", displays the 
source. The statement causing an error could be displayed in a 
similar manner. 

The stack command was then used to see what called what. 
The ouput shows that procedure "test" was called from command 
level, and then, in turn, called fun. While fun was executino, a 
quit occured and established a new command level. To determine 
whether fun was called from line 17 or line 27 of test, the use 
command is used to find the point at which test exited. Since 
"use" also sets the symbol pointer at the same time, the user can 
check if "s.num" has the correct value with the print command. 

The user decides that it would be worthwhile to trace the 
value of i. Rather than recompiling his program with a put 
statement added in a strategic location, probe allows him to set 
a break containino a print command to accomplish the same thino. 
Wanting to set the break after the do statement on line 16, the 
user searches for it with the find command, "list" is used to 
verify that the correct line was found. The continue command 
then causes probe to return (to command level). 

To abort the suspended proqram test, the user gives the 
release command to Multics. If he had done this just after 
quitting, he could not have used probe to find out much about 
what happened. 
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1 test* procedure; 

2 

3 declare 

4 

5 (i,j) fixed binary, 

6 Is structure based (p), 

7 2 num fixed binary, 

8 2 b (n refer (s.num)) float binary, 

9 p pointer, n fixed binary, 
10 sysprint file? 

II 
12 

13 n = 5? 

14 allocate s set (p)? 
15 

16 do i = 1 to s.num? 

17 s.b(i) = fun (i, 1)? 

18 end? 

19 put skip list (s.b)i 
20 

21 do j - s.num to I by -I ; 

22 s.b(j) = fun (-j, -I); 

23 end? 

24 put skip list(s.b)? 
25 

26 return? 

27 

28 

29 funs procedure (b, i) returns (float binary); 

30 

31 declare 

32 (b, i) fixed binary? 
33 

34 if b - 

35 then return (1); 

36 else do? 

37 b = b - i? 

38 return (2**b + fun (b, i))? 

39 end? 
40 

41 end fun; 

42 

43 

44 end test? 
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The program Is started once again, but now, after each time 
line 16 is executed, the break occurs and probe prints the value 
of i. Clearly, it is not being incremented as it should. Since 
this approach is not producing any useful information, the user 
aborts the program and trys to delete the break. The status 
command is used to tell what breaks have been set in the segment 
test, and then to see the break set. The break is then deleted 
with the reset command. Note that if there had also been a 
"Break before 16", then the command "reset at 16" would have 
deleted both. 

The user next decides to see what is going on in fun, so he 
sets a-»break to halt it every time it is invoked. By looking at 
the listing, he knows that the first statement in fun is on line 
34, so he "positions" the source pointer to that statement and 
"inserts" a "stop". To accomplish the same thina, "insert 34x 
stop" could have been used. 

The program halts when the break before line 34 is reached. 
The user displays b and i getting the values he expected. The 
where command is also used to see what the state of things is. 
Continue ("c") restarts fun which calls itself recursively and 
stops again. The stack command (showing the last five frames) 
verifies that fact. The user prints the b in the current 
instance of fun (at level 2) and in the previous one (at level 
3). Mistakenly expectina the b's at different levels to be 
different, he gets suspicious. The variable "i" has the value 
expected, but the symbol command shows that it is wrong one — 
the parameter to fun, not the loop index. To get the correct 
one, he must look in the frame belonging to the procedure test. 
This "i" has been set to zero. The user then realizes his error. 
The function is modifying its argument (the loop index "i") on 
line 37. Done with debuoging the program, "reset" is used to 
delete the currently active break (the one that just occurred), 
and the program is aborted. 
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1 > pi I test -table 

2 PL/I 

3 r 1248 3.211 28.336 280 
4 

5 > test 

6 (quit) 

7 QUIT 

8 r 1250 5.371 6.702 52 level 2, 10 
9 

10 > probe 

11 Condition quit raised at line 38 of fun. 

12 > list 

13 return (2**b + fun (b, i)); 

14 > stack 

15 1 command_processor_ 

16 2 release_stack 

17 3 unclaimed_siqnal 

18 4 real_sdh_ 

19 5 return_to_rlng_0_ 

20 6 fun quit 

21 7 test 

22 8 command_orocessor_ 

23 .9 listen_ 

24 10 process__overseer_ 

25 11 real_init_admin_ 

26 > use level 7 

27 > list 

23 s.b(i) = fun (i, 1); 

29 > print s.num 

30 5 

31 > find "i = 1"; list 

32 do i = I to s.num? 

33 > append* print i 

34 > continue 

35 r 1252 1.375 16.394 354 level 2, 10 
36 

37 > release 

38 r 1252 .126 .922 19 
39 

40 > test 

41 1 

42 1 

43 1 

44 1 

45 (quit) 

46 QUIT 

47 r 1252 3.069 .650 25 level 2, 12 
48 
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49 

50 

51 

52 

53 

54 

55 

56 

57 

58 

59 

60 

61 

62 

63 

64 

65 

66 

61 

68 

69 

70 

71 

72 

73 

74 

75 

76 

77 

78 

79 

80 

81 

82 

83 

84 

85 

86 

87 

88 

89 

90 

91 

92 

93 

94 

95 

96 



> release 

r 1253 .092 .937 20 

> probe test 

> status test 

Break after line 16. 

> status after 16 

Break after line 16* print I 

> reset at 16 

Break reset after line 16 of test. 

> position 34 

> list 

if b = 

then return (1); 

> inserts stop 

> continue 

r 1255 .781 12.356 333 

> test 

Stopped before line 34 of fun. 

> print b 

1 

> where 

Current line is line 34 of test. 
Using level 2* fun. 
Control at line 34 of fun. 

> print i 

1 

> c 

Stopped before line 34 of fun. 

> stack 5 

1 break 

2 fun 

3 fun 
4. test 

5 command_processor_ 

> print b 



> print b[-1 ] 



> print i 

1 

> symbol i 

Attributes are: fixed binary(17,0) aligned parameter 
Declared ins fun. 

> use test 

> print i 
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91 > reset 

98 Break reset before line 34 of test. 

99 (quit) 

100 QUIT 

101 r 1307 4.870 64.788 1544 level 2, 18 
102 

103 > release 

104 r 1307 .076 .992 31 



